package com.yss.system.domain;

import java.util.ArrayList;
import java.util.List;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;

import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.yss.common.core.annotation.EasyExcel;
import com.yss.common.core.utils.easyexecl.IntegerConverter;
import lombok.Data;
import lombok.EqualsAndHashCode;
import com.yss.common.core.web.domain.BaseEntity;

/**
 * 菜单权限表 sys_menu
 */
@Data
@EqualsAndHashCode(callSuper = false)
@TableName("sys_menu")
public class SysMenu extends BaseEntity {
    private static final long serialVersionUID = 1L;

    /**
     * 菜单ID
     */
    @ExcelIgnore
    @TableId("ID")
    private String id;

    /**
     * 菜单名称
     */
    @NotBlank(message = "菜单名称不能为空")
    @Size(min = 0, max = 50, message = "菜单名称长度不能超过50个字符")
    @TableField("MENU_NAME")
    private String menuName;

    /**
     * 父菜单名称
     */
    @ExcelIgnore
    @TableField(exist = false)
    private String parentName;

    /**
     * 父菜单ID
     */
    @TableField("PARENT_ID")
    private String parentId;

    /**
     * 显示顺序
     */
    @NotNull(message = "显示顺序不能为空")
    @TableField("ORDER_NUM")
    private Integer orderNum;

    /**
     * 路由地址
     */
    @Size(min = 0, max = 200, message = "路由地址不能超过200个字符")
    @TableField("PATH")
    private String path;

    /**
     * 组件路径
     */
    @Size(min = 0, max = 200, message = "组件路径不能超过255个字符")
    @TableField("COMPONENT")
    private String component;

    /**
     * 路由参数
     */
    @TableField("QUERY")
    private String query;

    /**
     * 是否为外链（0是 1否）
     */
    @TableField("IS_FRAME")
    private String isFrame;

    /**
     * 是否缓存（0缓存 1不缓存）
     */
    @TableField("IS_CACHE")
    private String isCache;

    /**
     * 类型（M目录 C菜单 F按钮）
     */
    @NotBlank(message = "菜单类型不能为空")
    @TableField("MENU_TYPE")
    private String menuType;

    /**
     * 显示状态（0显示 1隐藏）
     */
    @TableField("VISIBLE")
    private String visible;

    /**
     * 菜单状态（0正常 1停用）
     */
    @ExcelProperty(value = "状态", converter = IntegerConverter.class)
    @EasyExcel(readConverterExp = "1=正常,2=停用")
    @TableField("STATUS")
    private Integer status;

    /**
     * 权限字符串
     */
    @Size(min = 0, max = 100, message = "权限标识长度不能超过100个字符")
    @TableField("PERMS")
    private String perms;

    /**
     * 菜单图标
     */
    @TableField("ICON")
    private String icon;

    /**
     * 子菜单
     */
    @ExcelIgnore
    @TableField(exist = false)
    private List<SysMenu> children = new ArrayList<>();
}
